/**
 * Copyright (c) 2013-Now http://aidex.vip All rights reserved.
 */
import Vue from 'vue';
import App from './App';
import config from '@/common/config.js';
// import VConsole from 'vconsole';
// if (process.env.NODE_ENV === 'production') {
// new VConsole({ theme: 'dark' });
// }

import navBar from '@/components/navBar/index.vue'
import layout from '@/components/layout/index.vue'
import toHome from '@/components/toHome/index.vue'
Vue.component('navbar', navBar)
Vue.component('layout', layout)
Vue.component('tohome', toHome)
Vue.config.productionTip = false;

App.mpType = 'app';

// 引入全局 uView 框架
import uView from 'uview-ui';
Vue.use(uView);
// 全局存储 vuex 的封装
import store from '@/store';
import { VueJsonp } from './common/jsonp'
Vue.use(VueJsonp)

// 引入 uView 提供的对 vuex 的简写法文件
let vuexStore = require('@/store/$u.mixin.js');
Vue.mixin(vuexStore);

// 引入 uView 对小程序分享的 mixin 封装
let mpShare = require('uview-ui/libs/mixin/mpShare.js');
Vue.mixin(mpShare);

// Vue i18n 国际化
import Bridge from '@/common/bridge.js';
import VueI18n from '@/common/vue-i18n.min.js';
Vue.use(VueI18n);

// i18n 部分的配置，引入语言包，注意路径
import lang_zh_CN from '@/common/locales/zh_CN.js';
import lang_en from '@/common/locales/en.js';

Vue.prototype.$bridge = Bridge
const i18n = new VueI18n({
	// 默认语言
	locale: 'zh_CN',
	// 引入语言文件
	messages: {
		'zh_CN': lang_zh_CN,
		'en': lang_en,
	}
});
// 由于微信小程序的运行机制问题，需声明如下一行，H5和APP非必填
Vue.prototype._i18n = i18n;

Vue.prototype.getImgSrc = function (img) {
	return config.imagePath + img
};

Vue.prototype.back = function () {
	const pages = getCurrentPages();
	if (pages.length > 1) {
		uni.navigateBack({
			delta: 1,
		});
	} else {
		if (this.vuex_flag === "user") {
			uni.redirectTo({
				url: "/pages/sys/home/index",
			});
		} else {
			uni.redirectTo({
				url: "/pages/sys/home/hall",
			});
		}
	}
};

Vue.prototype.logOut = function (cb) {
	uni.showModal({
		content: '是否确认退出登录？',
		success: (res) => {
			if (res.confirm) {
				if (window) {
					localStorage.clear();
				} else {
					uni.clearStorageSync()
				}
				this.$u.api.wxLogOut().then(res => {
					this.$u.toast("退出成功");
					this.$store.dispatch('init')
				})
				cb && cb();
			} else {
			}
		}
	})

};

const app = new Vue({
	i18n,
	store,
	...App
});

import { replaceAll } from '@/common/common.js'
Vue.prototype.replaceAll = replaceAll

// http 拦截器，将此部分放在 new Vue() 和 app.$mount() 之间，才能 App.vue 中正常使用
import httpInterceptor from '@/common/http.interceptor.js';
Vue.use(httpInterceptor, app);

// http 接口 API 抽离，免于写 url 或者一些固定的参数
import httpApi from '@/common/http.api.js';
Vue.use(httpApi, app);
app.$mount();
